ArgentinaPrograma 
YoProgramo 


por Leonardo Blautzik, Federico Gasior y Lucas Videla 


Julio / Diciembre 2021 


SQL (Structured Query Language) 


El lenguaje estructurado de consultas 
Utilizado para interactuar con las RDBMS 
Se utiliza para: 


« Administrar y definir tablas y estructuras 
» Operaciones CRUD 
* Tareas de administración (seguridad, backups, importaciones, etc) 


* Lenguaje declarativo, basado en álgebra relacional y en calculo 
relacional basado en tuplas 

« Existe un estándar el cual es una base para extensiones 

« Estas extensiones suelen incluir ciertas estructural de lenguaje 
procedural 


Sublenguajes dentro de SQL 


+ DQL: Data Query: consulta pura (select sin from ni where) 

+ DML: Data Manipulation: manipulación de datos (select, insert, delete, 
entre otros) 

+ DDL: Data Definition: manipulación de tablas y esquemas 

« DCL: Data Control: autorización (conceder o denegar ciertos comandos 
a ciertos usuarios/grupos) 


SQLite 


Abrimos la aplicación ya instalada DB Browser for SOLite 


Creamos desde allí una base de datos para trabajar 


¿¿¿Un archivo??? 


SQLite sólo utiliza un archivo de ciertas características para almacenar su 
base de datos 


Otros motores utilizan un enlace hacia los archivos en forma de servicios, 
mientras que SQLite tiene una bandera interna para saber si lo están 
escribiendo, para que otro no lo haga a la vez 


Durante una transacción (por ahora sinónimo a estar escribiendo el archivo), 
SQLite guarda información adicional en un segundo archivo de rollback. 
Este archivo sirve para recuperar información de operaciones si el sistema 
operativo o la aplicación de acceso falla o finaliza abruptamente 


Tipos de datos 


La mayoría, por no decir todos los motores de base de datos, utilizan tipado 
estático; excepto por SQLite 


Estos determinan el tipo de dato según el contenedor (es decir, el tipo de la 
columna) 


SQLite permite almacenar en cada celda cualquier tipo de dato 


¿Entonces existen igualmente tipos de datos? 

Si. Se utilizan más como una sugerencia llamada “afinidad de datos”. Está 
afinidad hará que algunas columnas, dada la opción, preferirán usar un tipo 
de dato sobre otro 


Listado de afinidades 
* TEXT 
+ NUMERIC 
+ INTEGER 
+ REAL 
+ BLOB 


¿Y fechas? 
Se manipulan a través de funciones de fechas incluidas. Algunos formatos 
que soporta: 


« Como texto: 1508601 (“YYYY-MM-DD HH:MM:SS.SSS”) 
« Como entero: Unix time (Segundos desde 1970-01-01 00:00:00 UTC) 


CREATE TABLE (Crear tabla) 


TEMPORARY 
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CONSTRAINT (Restricciones) 


ñ CONSTRAINT AE 
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COLA 


foreign-key-clause 
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ALTER TABLE (Editar tabla) 
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schema-name 


DROP TABLE (Borrar tabla) 
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INSERT 


INSERT INTO "tabla" 

("columnal”", "columna2", "columna3") 
VALUES 

('valor1'", 2, NULL), 

('valor3', 4, NULL), 

('valor5', 6, NULL); 
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UPDATE 


UPDATE "tabla" 

SET 

"columnal" = 'datol', 
("columna2", "columna3") = 
WHERE "columna2” IS NOT NULL 
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DELETE 


DELETE FROM "tabla" 

WHERE "columnal" > 10 AND ( 
"columna2" = 'Lunes' OR 
"columna3" = 1 -—-- TRUE 

); 
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¡Muchas Gracias! 


continuará... 


